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SENDING AND/OR RECEIVING SERIAL DATA WITH BIT 
TIMING AND PARALLEL DATA CONVERSION 

CROSS REFERENCE TO RELATED APPLICATIONS 

The present invention is related to an allowed application entitled, "BIT CLOCK 
WITH EMBEDDED WORD CLOCK BOUNDAR," Serial no. 10/802,436 filed on 
March 16, 2004, and to an application entitled, "ARCHITECTURE FOR 
BIDIRECTIONAL SERIALIZERS AND DESERIALIZER," Serial no. 10/802,372 filed 
on March 16, 2004. Both of these applications are owned by the same entity, and are 
both incorporated herein by reference. 

BACKGROUND OF THE INVENTION 

Field of the Invention 

The present invention relates to data transmission, and more particularly to serial- 
izing and sending, bit by bit, data where the data word boundary is determined in order to 
properly receive and de-serialize the data. 

Background Information 

FIG. 1 illustrates a known serializer in a block schematic form. A parallel data 
word 10 is loaded into a buffer register 12 with a word clock 14. The word clock 14 is 
also fed to a phase locked loop (PLL) or a delay locked loop (DLL) 16, hereinafter PLL 
will be used to refer to both the PLL and DLL. The PLL generates a bit clock 1 8 that 
loads the shift register 20 and subsequently shifts out the data in the shift register 20 seri- 
ally bit by bit through a cable or transmission line driver 22. The bit clock 18 that shifts 
the data out bit by bit stays synchronized to the bit positions within the word by the PLL. 

1 



PATENT 
112055-0079U 
17732-67320.00 

Along with the serial bits from driver 22 a word clock 24 is output via driver 26. The 
receiver will be able to distinguish the beginning and ending of the serial data stream by 
referencing the bit stream via the word clock. 

FIG. 2 shows a receiver circuit that de-serializes the bits to form words. The se- 
5 rial data 30 is input to a shift register 32. The word clock 34 is input to a PLL 36 that 
generates a bit clock 38 that is synchronized to the bit location in a word by the PLL. 
With this synchronization, the bit clock 38 properly loads the bit stream into the shift reg- 
ister 32. When the word has been received by the shift register 32 (as determined from 
the word clock), the PLL outputs a clock 40 that loads the parallel data in the shift regis- 
io ter 32 into a buffer register 42. The word data 44 is in parallel form ready for use in the 
receiving system. 

FIGS. 1 and 2 contain a buffer register that holds the word to be sent or the word 
just received. The buffer allows nearly the entire time for a word to be sent or received 
before the next word is loaded. The logic and the timing to accomplish these tasks are 
15 well known. However, the buffer registers are not required, and if not used then the word 
to be sent and the word received must be loaded during a bit time. Again such designs 
are well known in the art. 

FIG. 3 shows a complete bidirectional system using the serializers as in FIG. 1 
and deserializerdeserializers as in FIG. 2. Note that there are eight data lines and a single 
20 clock into each serializer and out from each deserializerdeserializer. The data and clock 
lines between the serializer and the deserializerdeserializer are typically differential sig- 
nals each using two conductors. 

The serializer/deserializerdeserializers of FIG. 3 each contain a PLL that are 
common in such devices,but PLL's consume significant power, are complex, require long 
25 locking times, and occupy considerable chip real estate. It would be advantageous to dis- 
pense with PLL's. 

FIG. 4 is a timing diagram that shows a generic timing chart that illustrates the se- 
rial sending of a framed ten bit word. A word clock 60 is fed to a PLL that generates a 
synchronous bit clock 62, the word clock 60 must occur often enough for the PLL to re- 
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main locked. The data bits are loaded into a shift register using a word clock edge. Then 
the data bits in the shift register are shifted out serially by the bit clock 62. In FIG. 4 a 
eight bit word is shifted out on the rising edge of the bit clock 62. 

A similar operation applies to the receiving of the serial data. In this case, the 
5 word clock is received and applied to a PLL that generates a synchronous (to the word 
clock) bit clock that is used to load the data bits into a receiving shift register. Data bits 
must be stable when the clocks cause the data bits to be sent and to be received. Time 
delays are designed into such systems to accomplish this, as known in the art. In the case 
shown, the data bits are sent out synchronously where the lowest order bit of the next 
10 word is sent out directly after the most significant bit of the prior word. In other in- 
stances the data may be sent out asynchronously, typically using a start and stop bit that 
frames the data bits. In both the synchronous and asynchronous cases, system means 
must be employed, as are well known in the art, to prepare the sender and the receiver to 
properly send and receive the data. Also, systems are arranged to send data alternately 
is then to receive data; while other systems can send and receive simultaneously. The for- 
mer is referred to as half duplex and the latter as duplex. Again, system designers under- 
stand the limitations and requirements of such systems to properly send and receive data. 

It is axiomatic that the receiving system must be able to distinguish data word 
boundaries from a stream of serial bits, as discussed above. 

20 The prior art designs use PLL to provide synchronous bit clocks at both the send- 

ing and the receiving systems. However, PLL's occupy significant real estate on a die 
and consume considerable power and time before being locked. 

In general, transferring serial data offers an advantage in that the cable running 
between the sending and receiving systems need only have a few signals (if differential 
25 signals, one data pair and one clock pair) carrying wires (and, of course, if single ended a 
return wire or wires). In contrast, sending data over cables in parallel requires line driv- 
ers for each bit in a word and a clock driver. These parallel drivers consume high power 
and output high currents that create significant system noise. 
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In applications where cables or transmission lines are not used, but where parallel 
data is sent between integrated circuit packages, many pins on those packages must be set 
aside for each bit of the parallel data. In the newer designs, using sixty-four and one hun- 
dred and twenty-eight bits, the pins available on the packages become a design limitation. 

5 Larger packages, ball grid arrays, and similar packages that provide pins over the entire 
bottom surface of a package address this problem. However, the problem persists. Ap- 
plications that may suffer from these limitations include virtually all computing systems 
with complex displays, e.g. cell phones, desk-top and lap top computers, electronic 
games, computing systems with off-chip memory, any computing system addressing bulk 

10 memory, and electronic instrumentation, monitoring and controlling equipment. 

FIGS. 5 and 6 are illustrations of buffer circuits that may use logic level transla- 
tors between the various different voltages used by different logic families, for example, 
TTL, low level TTL, CMOS, and current mode logic families. 

FIG. 5 shows bidirectional buffers 70 that drive the A(0-7) signals to the B(0-7) 
is signals when the AtoB signal is high. The signals travel the opposite direction when the 
BtoA signal is high. A single bidirectional buffer circuit is shown in 70 and, in this in- 
stance of eight bits, the parallel buffers for the other seven bits are indicated by 70/ Prior 
art replacement of these buffer style circuits with serializers suffers from the power dissi- 
pation and complexity of the PLL's, the need for a reference clock, the lock time of the 
20 PLL, and the chip real estate occupied. In FIGS. 5 and 6 as shown, the AtoB and BtoA 
signals are low true. The DIR and EN- signals control the direction. In this case, the EN- 
must be low to allow the DIR signal to determine the data flow direction. If EN- is high, 
both the BtoA and AtoB are high and the A and B signals are isolated from each other. 

FIG. 6 shows a buffer-type circuit where the eight data bits A(0-7) are clocked 
25 into the D-type flops, one bit shown as 80. The CK AtoB would load AO into the flop 81 . 
The AO data is output as Q flop signal and then to the B0 line when AtoB is high. Simi- 
lar action occurs from sending B0 to the AO line when BtoA is high. The circuitry for the 
other seven bits is indicated by 80.' 
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It would be advantageous to use a serializer to replace the buffers of FIGS. 5 and 
6 without the disadvantages of using a PLL. 

Up to the present time, serializing and de-serializing data entails using PLL's that 
are complex and costly of power chip space and time, as discussed above. However, se- 
5 rializing and de-serializing would find greater acceptance if these limitations were re- 
moved. 

SUMMARY OF THE INVENTION 

In view of the foregoing background discussion of the prior art, the present inven- 
tion provides advantages in serializer/deserializerdeserializer and a method for sending 
10 and receiving serial data without using phase of delay locked loops. The serial- 

izer/deserializerdeserializer sends out a data word bit by bit and receives a data word bit 
by bit. In preferred applications, the data word bits are sent out with word boundary of 
framing bits and sometimes with filler bits. The boundary bits help distinguished differ- 
ent data words. 

15 A register for holding the data word is loaded from a parallel computer bus and 

the output of the register is connected to a serial output data port for sending the data bits 
out over, preferably, a matched transmission line. In a preferred embodiment, a free run- 
ning pulse generation or clock, that is not locked to any reference signal, is connected to a 
control input on the register after a data word has been loaded into the register. Herein, 

20 the word pulse generator and clock are used synonymously as will be understood by 
those practitioners in the art. The stored word data bits and boundary bits are serially 
output in response to the clock. The pulse generator signals are also sent out in parallel 
with the serial data bits. The receiver will use these signals to load in the bits as they ar- 
rive. 

25 In another preferred embodiment, a gated clock is employed. In this case the sig- 

nal that loads the data word to be sent is used to start a pulse generator that sends or shifts 
out the data word and, as before, any boundary or framing bits. 

In yet another preferred embodiment, using either the free running or the gated 
pulse generator, a change in the data word content, at least one bit changes state, is de- 
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tected and initiates that changed word being sent out serially with a bit defining pulse 
signal. Either the free running or the gated pulse arrangement may be used with this em- 
bodiment. 

The deserializerdeserializer includes a serial port for receiving a data word bit by 
5 bit into a second register for storing the bits. The second register has a data input and a 
control input. There is a clock signal received with the received serial data bits that de- 
fines the received second data word bits. This is used to clock the data into the second 
register. 

In a preferred embodiment, a bi-directional data line and a bi-directional clock 
10 line are provided that are buffered from the serializer/deserializerdeserializer electronics 
so that the data and clock signal flow directions may be reversed. In a preferred em- 
bodiment, a parallel data word is loaded into a shift register by a word or load signal. 
This might be an addressed write (a load signal) from a computer system parallel bus. A 
clock shifts the data out over the data line. This shift clock is synchronized with the word 
15 clock so that the data is properly loaded before shifting occurs. The shift clock is modi- 
fied before or after being sent out over the bi-directional clock line coincident and syn- 
chronized with the data bits being sent. 

In a preferred embodiment, the clock traveling with the data is delayed before or 
after sending, so that a clock edge or other such signal is present to indicate when a data 
20 bit is stable. 

In another preferred embodiment, a word load signal, sometimes referred to as a 
word clock, latches data into buffer registers. Between a serializer and a 
deserializerdeserializer, the data lines are bidirectional as is the bit clock line. There is an 
overall master or controller that handles the data and clock direction reversals so that in- 

25 formation is not lost. 

In another preferred embodiment, the sender and the receiver turn around the 
data/clock signal directions in response to control/status line or lines between the two. 
Protocols may be developed by those skilled in the art to ensure that proper control of the 
communications between the sending and receiving systems. For example, a busy signal 

30 may be used where if busy was not asserted, the system wanting control would assert 
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busy. At some random time, the system would dis-assert busy in case the prospective 
receiver asserted busy at the identical time. If the busy signal remained asserted, that side 
would delay taking control until the other side finished and dis-asserted busy. If the busy 
signal went dis-asserted, that side would re-assert the busy and send its message. Infor- 
5 mation being transferred would typically have an error check system, so that if there was 
contention remaining on the communication, improper information would be detected 
and the transfer re-tried at some later time. Such techniques and systems are well known 
in the art. 

In another preferred embodiment, the sending system may continuously output 
10 data words without any handshake. The system and the receiver must be arranged to re- 
ceive the words in a timely fashion. 

The present invention also provides means for incorporating word boundaries 
into and determining data word boundaries from a stream of data bits. More information 
may be found in the related applications referenced above. One or two boundary data 
is bits are typically added to the data bits of each word. The boundary bit or bits may be 
located within the word data bits or after or before the word data bits. 

When two boundary bits are used, they are arranged so that a logic level transition 
must occur between the two boundary data bits. The transition may be either high to low 
or low to high. A bit clock accompanies the serial data bits to determine when each bit is 
20 stable and suitable for. However, the bit clock is arranged with no logic level transitions 
during the word boundary bits. The receiving system detects a word boundary logically 
by sensing a data bit transition when the bit clock exhibits no transition. 

When one boundary bit is used, in a preferred embodiment, the boundary data bit 
exhibits a double frequency, and, if the bit clock is maintained at a constant logic level 
25 during the double frequency, a word boundary is detected. 

In other preferred embodiments, the data line is bi-directional but there are two 
unidirectional clock lines. In yet other preferred embodiments, both the data lines and the 
clock lines are unidirectional. This embodiment is needed when high speed data is sent 
over longer distances. 
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It will be appreciated by those skilled in the art that although the following De- 
tailed Description will proceed with reference being made to illustrative embodiments, 
the drawings, and methods of use, the present invention is not intended to be limited to 
these embodiments and methods of use. Rather, the present invention is of broad scope 
and is intended to be defined as only set forth in the accompanying claims. 



BRIEF DESCRIPTION OF THE DRAWINGS 

The invention description below refers to the accompanying drawings, of which: 

FIGS. 1 and 2 are block diagram schematics of a prior art serializer and 
deserializerdeserializer; 

FIG. 3 is a system block diagram of a prior art duplex system; 

FIG. 4 is a representative prior art timing chart; 

FIG. 5 is a block diagram schematic of a prior art directional buffer; 

FIG. 6 is ia block diagram schematic of a prior art directional buffer incorporating 
a storage register; 

FIG. 7 is a generalized block diagram incorporating the present invention; 

FIGS. 8 A and 8B are block diagram schematics of two clocking schemes used 
with preferred embodiments of the invention; 

FIGS. 9 and 10 are block diagram schematics showing two preferred versions of 
the present invention; 

FIG. 1 1 is a schematic block diagram and timing diagram showing detection of a 
data bit change; 

FIG. 12 is a block diagram of an alternative preferred embodiment; 
FIGS. 13, 14, 15, 16, are block diagram circuits showing some of the system ar- 
rangements using the present invention; 

FIGS. 17 and 18 are system block diagrams showing control; and 

FIGS. 19. 20, and 21 are system block diagrams using the present invention. 
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DETAILED DESCRIPTION OF AN ILLUSTRATIVE 

EMBODIMENT 

FIG. 7 is a generalized system block diagram embodying the present invention. 
As described below, many variations of FIG. 7 will be described. These implementations 
5 represent some of the configurations and operations where the present invention will be 
advantageous. But, the following descriptions are not exhaustive, as those practitioners 
in the art will know of or develop other configurations using the present invention. 

FIG. 7 shows a computer system 92 that may be virtually any electronic system 
where parallel data is available for reading or writing, that is, besides usual computer sys- 
10 terns, camera electronics, memory electronics, keyboards, scanners, print heads, wireless 
communications, etc. among other such systems known in the art that may employ the 
present invention. 

It is helpful in describing preferred embodiments, to distinguish "synchronous" 
implementations where data is being sent continuously at a regular rate without using any 
15 handshaking. Data would be sent regardless of any indication that the system was ready 
for new data or not. An asynchronous implementation would employ handshaking sig- 
nals, e.g. ready for new data and data is ready for reading, before sending new data. 
These terms are well known in the art. The following system descriptions incorporate 
some synchronous and some asynchronous system arrangements. 

20 The computer system interfaces with a serializer/deserializerdeserializer 90 via a 

parallel data port or contacts. The serializer 90 serializes the parallel data and sends it to 
the deserializerdeserializer/serializer 90,' where that data is de-serialized and read in par- 
allel by the computer system 92.' Data is transferred from computer system 92' to 92 in 
a similar fashion. In one arrangement there is only a serializer in 90 and only a 

25 deserializerdeserializer in 90.' In this case the data transfer is one way, or simplex. 
Similarly, the system may be configured in the opposite direction with only a 
deserializerdeserializer in 90 and a serializer in 90.' However, in most applications there 
will be both a serializer and a deserializerdeserializer, as shown, in both systems 90 and 
90.' 
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The parallel interfaces 96 and 96' have parallel data usually arranged in a bi- 
directional bus with buffers enabled depending on the direction of the data. The parallel 
interface also shows two generic control lines, WORD LOAD and RDY. As shown, 
these lines do not have a direction symbol since they may originate in either the computer 
systems or the serializer/deserializerdeserializer. In one arrangement, the computer sys- 
tem 92, when RDY is true, will load the next word into the serial- 
izer/deserializerdeserializer with the WORD LOAD signal. However, in another ar- 
rangement, the serializer may, after sending out a data word, assert the WORD LOAD 
signal to strobe in a new parallel word from the computing system 92. The computing 
system would then use the WORD LOAD to bring up the next word to be serialized. 

When the computer system 92 or 92' is receiving a parallel data word from the 
deserializerdeserializer, the RDY line can be used as an indication that the data word is 
available over the data lines 96. However, in another arrangement, the RDY signal may 
be used to strobe the data into the computer system. For example, if the data were going 
directly into a memory system, the RDY signal may strobe in the data word and also in- 
crement an address counter to have the memory pointing to the next location. In the fol- 
lowing descriptions, the RDY and the WORD LOAD signal may be described with other 
acronyms that are easily understood to be functionally equivalent. 

The pulse generation and timing blocks of 90 and 90' may incorporate a number 
of different clock or pulse generation circuits known in the art. For example a free run- 
ning clock that is synchronized with the loading of a new word, either by an external or 
an internal WORD LOAD signal may be used. However, in another embodiment, a gate 
pulse generation circuit that is started by the WORD LOAD signal and ends when the 
data word and any boundary or framing bits have been sent. 

As discussed below, the clock circuitry itself may be via an inverter chain, some 
form of delay circuit, a crystal or a tank circuit (even an RLC type circuit with an induc- 
tive or equivalent component may be used). 

In yet another arrangement, the serializer/deserializerdeserializers 90 and 
90'output the pulse generation/timing signal 100 and 100.' These pulse signals may be 
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distributed to other serializer/deserializerdeserializers to provide a clock for such sys- 
tems. In one example, a free running pulse source that is started when powered up may 
be distributed for sending and receiving data via other serializ- 
ers/deserializerdeserializers. 

In addition to the many physical and functional arrangements or forms of the seri- 
alizer/deserializerdeserializer, pulse signals from a deserializerdeserializer, say in item 
90, may be sent to the sending serializer in 90' over the transmission cable 94. Then, the 
serializer in item 90', acting as a slave, uses the received pulse signals to serialize and 
send the data back to the deserializerdeserializer. 

Of note in FIG. 7, there is no phase or delayed locking circuitry in the serial- 
izer/deserializerdeserializers 90 and 90.' Furthermore, there is no reference of other 
clock or timing signal fed into the serialzer/de-serilizers for providing a locking refer- 
ence. The serializer/deserializerdeserializers have, instead, a pulse generator that is syn- 
chronized and/or gated to the sending and receiving of a data word. The inventive opera- 
tion shown in FIG. 7 employs the pulse generation as discussed herein, but also provides 
a bit clock traveling with the serialized data between the two systems 90 and 90.' This 
bit clock typically will have an edge that is delayed (either at the sender or the receiver) 
from the data edge so that the bit clock defines the stable portion of a data bit. Alterna- 
tively, as is known in the art, the receiver may provide the delay so as to load the bits er- 
ror free. 

The formatting of the data and the bit clocks in preferred embodiments of the pre- 
sent invention are well discussed in the related applications referenced above. These 
related disclosures detail implementations for protocols for generating and detecting word 
boundaries using the bit clock and additional boundary bits (or bit) in the data field. 

In operation, there may be many other variations of the operation and uses of the 
general block diagram of FIG. 7, and the present invention can be used to advantage in 
these many applications. Inventive implementations include the following independent 
arrangements: a) one direction serializer; b) one direction deserializerdeserializer; c) bidi- 
rection data lines; d) bidirection bit clock lines; e) unidirectional bit clock lines; f) unidi- 
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rectional data lines; g) handshaking; h) no handshaking; i) external word load generation; 
j) internal word load generation; k) free running synchronized pulse generation; 1) gated 
pulse generation; m) starting the serializing by a word load signal; and n) starting the se- 
rializing by a change in the data. The description of these implementations as "independ- 
ent" refers to the ability of those skilled in the art to employ virtually any of the enumer- 
ated arrangements without respect to the other arrangements, excepting, of course, where 
the arrangements are mutually exclusive (e.g. using handshaking or not). 

The following text describes particular, but non-exhaustive, preferred embodi- 
ments of the present invention. They are embodiments of the general system described 
above. 

In FIG. 7, the items 90 and 90' include pulse generation/timing blocks. FIG. 8A 
and 8B describe two preferred embodiments. FIG. 8A shows a gated ring oscillator. 
Here, when the EN signal 1 10 is true, the oscillator will output a series of pulses OUT 
112 whose timing depends on the delay time around the loop of inverters 1 14 and the 
NAND 1 16. The hysteresis of the Schmitt trigger inverter 115, although not necessary, 
helps to ensure proper oscillation at the designed frequency. The enable pulse occurs 
concurrently when a data word has been input from a computing system or from receiv- 
ing a deserializerdeserializer full data word. 

As is known in the art, pulse generators will typically be compensated for voltage, 
temperature and pressure. 

FIG. 8B shows a free running oscillator with a START signal that is generated at 
power up. In this embodiment, the OUT1 pulse signal is always present after being pow- 
ered. The Schmitt trigger 1 1 5 is present as are the inverters 1 14 that provide a delay, but 
other delay circuits may be used. When a word has been loaded or received from a com- 
puting system for serializing, the EN1 signal goes true. The flop 1 18 is set by an OUT1 
pulse, and the next OUT1 pulse is sent via the NAND 120 as the shift pulse to output the 
serialized data. A counter 122 may be used to count shift pulses so that when a full word 
and any boundary bits are output, the flop 1 18 is reset, and in addition the WORD load 
signal may go back to the computing system to set up the next word to be sent. The 
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counter may be reset (not shown) by when the WORD LOAD signal is true and the next 
OUT1 pulse 122. However, other ways to reset the counter may be used depending on 
system restrictions to ensure no lost or garbled data. 

In either clock or pulse circuit of FIGS. 8 A and 8B, if there were a five nanosec- 
ond (nsec) net delay through a total of five inverters, including the Schmitt and the 
NAND, the time of each high 1 17 and each low 1 19 would be five nanoseconds and there 
would be a period of ten nanoseconds and a frequency of 100MHz. More typically, each 
stage delay would be sub-nanosecond. As mentioned above, many other designs will 
known in the art that may be used to generate a bit clock. 

FIG. 8B illustrates a circuit that synchronizes the bit clock pulses to the signal that 
loads a new word for sending, noting that this signal may originate within the serial- 
izer/deserializerdeserializer or the computing system. The START signal is a signal, for 
example from power up, that starts the ring pulse generator running. In this case, com- 
pared to that in FIG. 8 A, the ring pulse generator is free running. When a new word is 
ready for sending, EN1 goes true and the flop 1 18 is set on the succeeding OUT1 signal. 
Then, the OUT1 signal is output via NAND 120 to shift out the data bits. The pulses are 
also counted so that when the full data word and any boundary bits have been sent, the 
flop 1 18 is reset. The counter 122 output may also be used to load in the next word ready 
to be sent. 

FIG. 9 shows one preferred embodiment of the invention. Here, a serial- 
izer/deserializerdeserializer 130/132 transfer data between the parallel A[0:7] 134 lines 
and the differential serial signal lines BDS+ and BDS- (BDS) 136. The parallel data on 
the data lines 134 are input to the serializer 130 that are then shifted out via the output 
buffer 138. A clock signal is output via the buffer 142 to accompany and define the serial 
data. The data lines BDS are bidirectional and data is received over these same lines via 
the input buffers 140. There is a received clock or pulse signal via the bidirectional clock 
BCK+/BCK- (BCKS) lines. The received data is input to a deserializerdeserializer using 
the received BCKS signals and assembled as a parallel data word in a register. The data 
is placed on the data lines 134 when to be read by the computing system. The direction 
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of the data and the clock buffers are determined by the direction circuit 144. When EN- 
is true (low) the DIR drives either BtoA or AtoB signals true thereby determining the 
data flow. This particular implementation of the present invention replaces the translator 
circuit shown in FIG. 5 5 the new circuit uses an edge detection mechanism 141 that ac- 
cepts any transition of a data edge as a signal to transfer the data out. If no data edge oc- 
curs or is available, the sending system would provide a strobe of load signal to initiate 
the transfer, for example, from an enable signal. Such signals are known in the art. 

FIG. 10 is an inventive replacement for the prior art circuit of FIG. 6 where data is 
strobed into a register. The circuit functions in a manner very similar to that of FIG. 9. 
The primary difference is that there is a strobe signal 148 that loads the parallel data into 
a register for serializing. That strobe starts a gated clock or provides the synchronization 
signal to the free running pulse generation circuitry. In either case, the loaded parallel 
word is shifted out serially via the buffers BDS along with a bit clock BCKS. When a 
word is being received, the data is received via the input buffers from BDS lines along 
with a received BCKS signal. The BCKS signal is used to shift the data into the 
deserializerdeserializer. The data is moved into a holding register 150. At about the 
same time, a signal CKP is generated and made available to the computing system to in- 
dicate that there is a word ready to input. In response thereto, the data is read by the 
computing system via the buffers 152 leading to the A[0:7] lines. 

Operation of systems of FIGS. 9 and 10 show a single, differential bi-directional 
data and a single differential bi-directional clock line. However, single non-differential 
may be used in some applications. Use of a single clock transmission line may useful at 
lower system speeds, but at higher speeds, separate data in, data out, clock in and clock 
out lines may be used. In such a case, there are two data lines each transferring unidirec- 
tional data in opposite directions and separate unidirectional clock lines with clocks trav- 
eling in opposite directions. The serializer/deserializers may also be operated with two 
clock lines but a single bi-directional data line, or a single bi-directional clock line and 
two unidirectional data lines. 
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The buffer circuits of FIG. 9 and 10 may be low voltage CMOS circuits with a 
nominal threshold of about Vi the powering voltage, VDD. The input buffers may be held 
off or three stated to conserve power when not active. 

Similarly, the output buffers are three state circuits that will source/sink 2 mA's at 
1 ,8V when active, and are held in the high -Z state when the device is not active. 

CMOS devices with low, 2mA, drive currents were used throughout embodiments 
of these circuits. However, TTL or LVTTL or even differential signaling could be used 
and the drive current could be of any logic type, from very low currents (sub-mA's) to 
very high currents (100's of mA's). In three state configurations, a bus hold circuit, as 
known in the art, may be used. 

FIGS. 9 and 10 illustrate two preferred embodiments of basic models for the fol- 
lowing discussions. 

FIG. 1 1 shows an example of an edge detection scheme that may be used as item 
146 in FIG. 9. Here, any (or all) transition on any of the data lines A[0:7] 134 will cause 
a clock pulse to occur at the clock inputs of the flops 158. Any change of state of the flop 
158 will cause the OUT signal to go high 160. This OUT signal will be the EN gate sig- 
nal 1 10 to the gated ring oscillator of FIG. 8A. After the data word is serialized, a RSTb 
162 signal resets the edge detection oscillator 146. If no edge in the data lines occur, an 
edge may be derived from another signal generated from the sending system, e.g. an en- 
able and/or a DIR signal that configures the circuit to send data in a given direction. The 
circuitry of FIG. 1 1 would change accordingly. 

For FIG. 1 1, the data transitions must be substantially at the same time, but this 
would be true for most any system outputting parallel data. 

In the above systems of FIGS. 9 and 10, the data lines (BDS+, BDS-) and the 
clock out lines (BCKS+, BCKS-) are typically differential pairs as shown, but may be 
single ended in other preferred embodiments. Line driver buffers 142 and 138 (FIG. 9) 
for differential pairs are well known in the art. These differential pairs will be referred to 
as CKS, and DS unless a specific reference is clearly referring to the individual signals. 
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As mentioned above, typically there will be a deserializerdeserializer packaged with the 
serializer 76. 

In some preferred embodiments, the serializer is a shift register, but in others a 
multiplexer, FIG. 12, is used for selecting the different bits may be used. The data is 
held in a register 182 and is connected to the output DS via multiplexer (MUX) 180. 
Control circuitry for implementing the sequencing of the MUX are well known in the art. 

FIGS. 13, 14, 15 and 16 show typical applications of the device illustrating a mas- 
ter /slave operation of two devices as shown in FIGS. 9 and 10. 

FIG. 13 illustrates a preferred serializer/deserializerdeserializer pair operating as a 
master/slave with unidirectional data transfers. One device 340 is arranged in mode #1 
with SER/DES signal set high, the device 340 acting as a serializer and master. Item 342 
is the slave operating as a deserializerdeserializer receiver of the data from 344. Device 
342 is arranged with SER/DES signal set low. WORD LOAD is a word clock input, or a 
load signal, synchronized with the clock circuitry 340 that generates a bit clock 344 with 
an embedded word boundary. The bit clock is received by the slave 342 via the CKS1 
port as shown. Register 348 receives parallel data 346 from a processor via DP M port 
that is loaded into the register 348. That data is serialized and sent out synchronously 
with the bit clock CKSO via the DS line. The CKSO and the DS are arranged so that 
each edge of the CKSO is used to load data at the slave 342. 

The slave 342 accepts the CKS1 and generates a word clock CK_P 350. The de- 
serialized DS data stream is loaded into the register 352 and made available on the DP S 
port together with the word clock CK_P so that the receiver processor can retrieve the 
sent data. 

FIG. 14 illustrates a master/slave operation where the clock is generated at the 
master but data flows from the slave to the master. Device 370 is arranged as a master 
deserializer. Device 370 delivers a bit clock CKSO from a reference clock, WORD 
LOAD, or a load signal, and a divider, but with no word boundary. The master receives a 
bit clock CKS1 from the slave, but the slave has introduced the word boundary that was 
missing from in the clock CKSO signal. The serializer control 376 in the slave device 
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372 receives the CKSO and introduces the word boundary into the CKSO' sent back to 
the sending device 370. The serilizer control 374 also introduces the word boundary data 
bits into the sent bit stream DS. Device 370 receives the serial data DS, parallelizes it 
and presents the parallel data to the processor bus DP_M with the REFCKM. The slave 
372 serializes parallel data stored in the register 374 and sends the serialized data bits by 
the CKP_S clock. 

FIGS. 15 and 16 illustrate bidirectional data with clock circuitry and control run- 
ning on both the master and slave device. The clocks running on either side of the serial 
transmission line are completely independent form each other. In each case, the master 
380 in FIG. 15 and 384 in FIG. 16 each accepts the WORD LOAD signal and generates 
a bit clock with an embedded word boundary. Parallel data is received, as described 
above, and sent synchronously with the bit clocks to the slave devices. In this applica- 
tion, the master accepts from the slave a bit clock with an embedded word boundary and 
generates a word clock CKP_M. The slave devices 382 and 386 operate as slave 
deserializers and accept the bit clock with the embedded word boundaries. The slaves 
generate the word clock CKPJS(M) and de-serialize the data stream using the CKS1 
clocks. Parallel data is written onto the DP_S port with the CKPS(M) clock. The slave 
also generates a synchronized bit clock based on the WORD LOAD signals and transmits 
this bit clock to the master. 

FIG. 17 shows an arrangement where there is a single data line and a single clock 
line between two devices 360 and 360' each similar to that in FIGS. 9 and 10. Here there 
is bidirectional data transfer where both data and clocks lines must be turned around to 
implement the bidirectional data transfers. The data transfers are half duplex and the 
modes and control of the items 360 and 360' must be arranged to accommodate the data 
reversal. The clock must be reversed and synchronized before data can be transferred. 
Control of 360 and 360' can be implemented as is known by system designers in this art 
field. For example, status lines 366 may be implemented or have an overall system man- 
ger 362 that controls both computing systems sending and receiving data to and from 
items 360 and 360' could implement the half duplex data transmission. For some appli- 
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cations this embodiment may be inappropriate principally due to turn around time and the 
dual use of the data and clock lines. 

Control of turning around the data and clock lines may involve protocols and ad- 
ditional control or status lines between a sender (serializer) and a receiver (deserializer) 
that may also include a master aware of conditions or status at both ends of the data and 
clock lines. In some embodiments, the bit clock on the transmission lines may remain 
cycling but without any word boundary included. Alternatively, the bit clock may remain 
in a low where the protocol requires a word boundary to be a bit clock high together with 
a data line transition so that no word boundary can be detected. Logical combinations 
may be used as practitioners in the art will be aware. In situations where no data has 
been transferred in some time, when the bit clock is always being sent, the sending sys- 
tem will begin a data transfer by sending, for example, eight bits of data followed by the 
word boundary. The receiver will receive the serial data not knowing if it has received 
data or not, if no word boundary is detected the eight bits of data are deemed to be not 
useful. In this case the next bit is shifted into the receiver shift register and the earliest bit 
is shifted out and lost. This continues until a word boundary is detected at which time the 
receiver stores the prior eight bits as it is now deemed to constitute a word. Again, prac- 
titioners in the art will understand and be able to institute other techniques that are well 
known in the art. 

FIG. 18 is similar to FIG. 17 except that there are two separate clock lines be- 
tween device 368 and 368/ This set up dispenses with clock turn around time and so can 
be used in applications that cannot use the system of FIG. 17. Both 368 and 368' are ar- 
ranged for acceptance of parallel data from their respective processors and both are ar- 
ranged to provide parallel data to those processors, as described earlier. In this imple- 
mentation, when either 368 or 368' are acting as a de-serialzer, the transferred bit clock is 
used to directly load the deserializer as discussed above. 

FIGS. 19, 20, and 21 diagrammatically show specific computing type systems 
employing the present invention. FIG. 19 shows a preferred embodiment of the present 
invention combined within a larger system. In this case the base processor 500 is trans- 
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ferring data to a camera 502, that may include a graphical processor 504. Here the moti- 
vation to serialize the data may be due to locations or form factors involved with the spe- 
cific chips including pin out limitations. If due to pin out limitations, the serializer 506 
may be packaged on the processor chip, but at the interface 510 it is evident that the seri- 
alizing permits data interchange with many fewer physical lines than at the parallel inter- 
faces at either the 500 chip or the 502 units. In this case, the base processor is receiving 
data bits from the camera, but in other preferred embodiments the data may be flowing 
from the base processor 500 to the camera 502 and back again. 

FIG. 20 shows a preferred embodiment of a computer system 510 having a CPU 
and local memory. Here, say due to pinout reasons, the system 510 has on board a serial- 
izer/deserializer preferred embodiment of the present invention interchanging data with a 
remote memory system 512. The remote memory system includes a corresponding seri- 
alizer/deserializer and, in this case, a mass memory. 

FIG. 21 shows a preferred embodiment of virtually any generic digital system 514 
sending and receiving serial data words with virtually any I/O device 516. 

It should be understood that above-described embodiments are being presented 
herein as examples and that many variations and alternatives thereof are possible. Ac- 
cordingly, the present invention should be viewed broadly as being defined only as set 
forth in the hereinafter appended claims. 

What is claimed is: 
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CLAIMS 

1 . A serializer for sending a data word out bit by bit, the serializer comprising: 

a register for holding the data word, the register having at least one data output 
and a control input; 

an output data port for serially outputting the data word bit by bit; 
means for connecting the data output to the output data port; 
a pulse generator free of external timing reference; 

means for connecting the pulse generator to the control input after a data word has 
been loaded into the register, wherein the data word bits are serially output in response to 
the pulse generator; and 

means for outputting signals from the pulse generator to define the serially output 
data word bits. 

2. The serializer of claim 1 further comprising means for outputting a data word 
boundary for separating data words, the data word boundary comprised of a combination 
of pulse generator signals and signals added to the serially output data word bits. 

3. The serializer of claim 2 wherein the means for outputting a word boundary com- 
prises means for adding two boundary bits to the serially output data word bits, wherein 
the added two bits always include a logic one and a logic zero in any order, and further 
wherein the means for connecting the pulse generator to the control input includes means 
to hold the signal at the control input at a constant logic level during the outputting of the 
two added bits. 

4. The serializer of claim 1 wherein the register is a shift register. 

5. The serializer of claim 1 further comprising a multiplexer arranged to select the at 
least one register output and connect it to the output data port. 
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6. The serializer of claim 1 further comprising means for loading the register from a 
parallel bus. 

7. The serializer of claim 1 wherein the pulse generator signals, that define the seri- 
ally output data word bits, provide a logic transition that defines when the data word bits 
being sent out are stable. 

8. The serializer of claim 1 wherein the pulse generator runs at twice the data bit rate 
wherein the data bits are shifted out on one pulse edge and the following pulse edge de- 
fines when the data word bits being sent out are stable. 

9. The serializer of claim 1 further comprising; 

a load signal that loads the data word bits into the register; and 
a synchronizer that synchronizes the pulse generator to the load signal, so that the 
data word bits are stable in the register before they are output. 

10. The serializer of claim 1 further comprising: 

means for connecting the pulse generator output to one or more additional 
registers for holding additional data words; and 

wherein the additional data words are delivered to one or more additional output 
ports and serially output in response to the pulse generator, and further wherein signals 
from the pulse generator are output that define the output data word bits. 

1 1 . The serializer of claim 1 further comprising: 

a load signal that loads the data word bits into the register; and 

means for enabling the pulse generator with the load signal, wherein the pulse 

generator provides a stream of pulses sufficient to output the data word after the data 

word bits are stable in the register. 
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12. The serializer of claim 1 further comprising: 

means for detecting a change in the data word to be sent, and in response thereto, 
causing the data word bits to be output via the output data port. 

13. A de- serializer arranged to receive a data word bit by bit, the deserializer com- 
prising: 

a serial input port for receiving the data word bit by bit; 

a register for storing the data word bits, the register having a data input and a con- 
trol input; 

means for connecting the serial input port to the register data input; 
a pulse generator receiving port for receiving pulses that defines the data word 
bits; and 

means for connecting the received pulses to the control input, wherein the data 
word bits are serially received and stored in the register. 

14. The deserializer of claim 1 3 further comprising means for detecting a data word 
boundary that separates data words, the data word boundary comprised of a combination 
of signals on the pulse generator receiving port and the signals on the serial input port. 

15. The deserializer of claim 13 wherein the word boundary signals on the pulse gen- 
erator receiving port and the signals on the serial input port comprise means for detecting 
two bits added to the data word bits, wherein the added two bits always include a logic 
one and a logic zero in any order, and further wherein the signals on the pulse generator 
receiving port stay at a constant logic level during the receipt of the two added bits. 

16. The deserializer of claim 13 wherein the register for storing data is a shift register. 

17. The deserializer of claim 13 further comprising means for reading the register 
contents via a parallel port. 
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1 8. A serializer/deserializer for sending a data word out bit by bit and for receiving a 
data word bit by bit, the serializer/deserializer comprising: 

a first register for holding the data word, the first register having at least one data 
output and a first control input; 

an output data port for serially outputting the data word bits by bit; 

means for connecting the first register at least one data output to the output data 

port; 

a pulse generator free of external timing reference; 

means for connecting the pulse generator to the first control input after a data 
word has been loaded into the first register, wherein the data word bits are serially output 
in response to the pulse generator; 

means for outputting signals from the pulse generator that define the serially out- 
put data word bits; 

a serial input port for receiving the data word bit by bit; 

a second register for storing the data word bits, the second register having a data 
input and a control input; 

means for connecting the serial input port to the second register data input; 

a pulse generator receiving port for receiving pulses that defines the data word 
bits; and 

means for connecting the received pulses to the control input, wherein the data 
word bits are serially received and stored in the second register. 

1 9. The serializer/deserializer of claim 1 7 further comprising: 

means for detecting a change in the data contents of the first register, and in re- 
sponse thereto, causing the data word bits to be output via the output data port; and 

data outputs from the second register wherein the second register contents are 
available. 

20. A process for serializing and sending a data word out bit by bit, the process com- 
prising the steps of: 
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holding the data word in a the register having at least one data output and a con- 
trol input; 

connecting the data output to the output data port; 
generating pulses free of external timing reference; 

connecting the pulse generator to the control input after a data word has been 
loaded into the register, wherein the data word bits are serially output bit by bit;and 

outputting signals from the pulse generator to define the serially output data word 

bits. 

2 1 . The process of claim 20 further comprising the steps of: 

outputting a data word boundary for separating data words. 

22 The process of claim 21 wherein the outputting a word boundary comprises the 
steps of: 

adding two boundary bits to the serially output data word bits, wherein the added 
two bits always include a logic one and a logic zero in any order; and 

maintaining the pulse generator output at a constant logic level during the output- 
ting of the two added bits. 

23. The process of claim 20 wherein the register is a shift register and the step of out- 
putting the data word bits includes shifting the data word bits out of the shift register. 

24 The process of claim 20 wherein the step of outputting the data word bits includes 
demultiplexing the register outputs and connecting them to the output data port. 

25. The process of claim 20 further comprising the step of loading the register from a 
parallel bus. 
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26. The process of claim 20 wherein the step of outputting signals from pulse genera- 
tor includes the step of providing a logic transition that defines when the data word bits 
being sent out are stable. 

27. The process of claim 20 further comprising the step of operating the pulse genera- 
tor runs at twice the data bit rate wherein the data bits are shifted out on one pulse edge 
and the following pulse edge defines when the data word bits being sent out are stable. 

28. The process of claim 20 further comprising the steps of: 
loading the data word bits into the register; and 

synchronizing the pulse generator to the load signal, so that the data word bits are 
stable in the register before they are output. 

29. The process of claim 20 wherein further comprising the steps of: 

connecting the pulse generator output to one or more additional registers for hold- 
ing additional data words; and 

wherein the additional data words are delivered to one or more additional output 
ports and serially output in response to the pulse generator, and further wherein signals 
from the pulse generator are output that define the output data word bits. 

30. The process of claim 20 further comprising the steps of: 
loading the data word bits into the register; and 

enabling the pulse generator with the load signal, wherein the pulse generator 
provides a stream of pulses sufficient to output the data word after the data word bits are 
stable in the register. 

3 1 . The process of claim 20 further comprising the steps of: 

detecting a change in the data word to be sent, and in response thereto, causing 
the data word bits to be output via the output data port. 
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32. A process for receiving and deserializing a data word bit by bit, the process com- 
prising the steps of: 

receiving the data word bit by bit via a serial input port; 

connecting the serial input port to the register data input; 

storing the data word bits in a register having a data input and a control input; 

receiving pulses that defines the data word bits; and 

connecting the received pulses to the control input, wherein the data word bits are 
serially received and stored in the register. 

33. The process of claim 32 further comprising the steps of: 
detecting a data word boundary that separates data words. 

34. The process of claim 33 wherein the step of detecting a data word boundary com- 
prises the steps of: 

detecting two bits added to the data word bits, wherein the added two bits always 
include a logic one and a logic zero in any order; and 

detecting signals on the pulse generator receiving port that remain at a constant 
logic level during the receipt of the two added bits. 

35. The process of claim 32 wherein the register for storing data is a shift register and 
the step of storing the data word includes shifting the data word bits into the shift register. 

36. The process of claim 32 further comprising the step of reading the register con- 
tents via a parallel port. 

37. A process for serializing and de-serializing a data word sent out bit by bit and re- 
ceived bit by bit, the process comprising: 

holding the data word in a first register having at least one data output and a con- 
trol input; 

connecting the data output to the output data port; 
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generating pulses free of external timing reference; 

connecting the pulse generator to the control input after a data word has been 
loaded into the first register, wherein the data word bits are serially output bit by bit;and 
outputting signals from the pulse generator to define the serially output data word 

bits; 

receiving the data word bit by bit via a serial input port; 

connecting the serial input port to a second register data input; 

storing the data word bits in the second register having a data input and a control 

input; 

receiving pulses that defines the data word bits; and 

connecting the received pulses to the control input, wherein the data word bits are 
serially received and stored in the second register. 

38. The process of claim 37 further comprising the steps of: 

detecting a change in the data word to be sent, and in response thereto, causing 
the data word bits to be output via the output data port; and 

reading the second register contents via a parallel port. 

39. A computer system comprising: 

a processor, memory, and an input/output apparatus, wherein the input/output ap- 
paratus comprises the serializer as defined in claim 1. 

40. A computer system comprising: 

a processor, memory, and an input/output apparatus, wherein the input/output ap- 
paratus comprises the serializer as defined in claim 1. 

41. A computer system comprising: 

a processor, memory, and an input/output apparatus, wherein the input/output ap- 
paratus comprises the deserializer as defined in claim 11. 
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42. A computer system comprising: 

a processor, memory, and an input/output apparatus, wherein the input/output ap- 
paratus comprises the serializer as defined in claim 18. 

43. A digital camera system comprising an optical system and means for digitizing 
optical signals and a processor, memory, and an input/output apparatus arranged for proc- 
ess the digitized optical signals, wherein the input/output apparatus comprises the serial- 
izer as defined in claim 1 . 

44. A digital camera system comprising an optical system and means for digitizing 
optical signals and a processor, memory, and an input/output apparatus arranged for proc- 
ess the digitized optical signals, wherein the input/output apparatus comprises the serial- 
izer as defined in claim 1 . 

45. A digital camera system comprising an optical system and means for digitizing 
optical signals and a processor, memory, and an input/output apparatus arranged for proc- 
ess the digitized optical signals, wherein the input/output apparatus comprises the 
deserializer as defined in claim 11. 

46. A digital camera system comprising an optical system and means for digitizing 
optical signals and a processor, memory, and an input/output apparatus arranged for proc- 
ess the digitized optical signals, wherein the input/output apparatus comprises the serial- 
izer as defined in claim 1 8. 

47. A digital memory system comprising: 

an input/output apparatus, wherein the input/output apparatus comprises the seri- 
alizer as defined in claim 1 . 
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48. A digital memory system comprising: 

an input/output apparatus, wherein the input/output apparatus comprises the seri- 
alizer as defined in claim 1 . 

49. A digital memory system comprising: 

an input/output apparatus, wherein the input/output apparatus comprises the 
deserializer as defined in claim 11. 

50. A digital memory system comprising: 

an input/output apparatus, wherein the input/output apparatus comprises the seri- 
alizer as defined in claim 18. 

51. A digital system having a parallel data bus comprising the serializer as defined in 
claim 1. 

52. The digital system of claim 51 wherein the digital system is selected from the 
group consisting of a scanner, a keyboard, and a printer, and further comprising the seri- 
alizer as defined in claim 1, or claim 1 1, or claim 18. 
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ABSTRACT OF THE DISCLOSURE 

A serializer and a deserializer are disclosed and shown operating singly or as a 
pair. The invention operates independently from any outside system reference clock. 
The inventive system provides an internal bit clock that serializes the data when sending 
and de-serializes the data when receiving. A bit clock or pulse travels with the data word 
bits to define when a bit is stable. The system uses word boundary bits operating with a 
bit clock to distinguish different data words, as described in the parent application. The 
system operates either synchronously or asynchronously with the base computer or other 
such digital system, including I/O devices. The invention finds use where new data to be 
sent is strobed into the serializer, but also where a change in the data bit content itself will 
cause the changed data to be loaded into the serializer and sent bit by bit. The system 
operates where new data is strobed or loaded by the serializer (not the base computer sys- 
tem) when the last data word has been sent. In this case a signal is generated when the 
last word has been sent in the serializer that causes new data to be loaded for sending. 
Half duplex and full duplex configurations as disclosed. Similar, corresponding opera- 
tions occur at the deserializer. 
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